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No: Claims 2-4,7-9 

Industrial applicability (IA) Yes: Claims 1-9 

No: Claims 



2. Citations and explanations 
see separate sheet 



VIII. Certain observations on the international application 

The following observations on the clarity of the claims, description, and drawings or on the question whether the 
claims are fully supported by the description, are made: 
see separate sheet 



Form PCT/IPEA/409 (Boxes 1-Vlll, Sheet 2) (July 1998) 



INTERNATIONAL PRELIMINARY International application No. PCT/GB99/03737 
EXAMINATION REPORT - SEPARATE SHEET 



Ad VIII) 
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generated from the same probability distribution independently of one another". It would 
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a particular classification with membership f(x), it follows in a trivial manner, that the 
misclassification fuzziness/likelihood is given by 1-f(x) which is the sum of all remaining 
possible classifications including the second most likely one. Thus by way complement 
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likely classification is contained. Thus there appears nothing new in the subject matter 
of claim 1 . 

For the purpose of the discussion of novelty the iid restriction introduced by the 
Applicants does not impose any effective restrictions. To assume that the fuzzy set 
examples of the various classes in Backer and Duin are generated independently from 
respective class probability distributions, does not have any influence on the fuzzy 
labelling. 

Similar comments apply to independent claims 5 and 6. 
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CLAIMS 

1 , Data classification apparatus comprising: 

an input device for receiving a plurality of training classified 
5 examples and at least one unclassified example; 

a memory for storing the classified and unclassified examples; 

an output terminal for outputting a predicted classification for the at 
least one unclassified example; and 

a processor for identifying the predicted classification of the at least 
1 0 one unclassified example 

wherein the processor includes: 

classification allocation means for allocating potential classifications 
to each unclassified example and for generating a plurality of classification 
sets, each classification set containing the plurality of training classified 
15 examples and the at least one unclassified example with its allocated 
potential classification; 

assay means for determining a strangeness value for each 
classification set; 

a comparative device for selecting a classification set containing the 
20 most likely allocated potential classification for the at least one unclassified 
example, wherein the predicted classification output by the output terminal 
is the most likely allocated potential classification according to the 
strangeness values assigned by the assay means; and 

a strength of prediction monitoring device for determining a 
25 confidence value for the predicted classification on the basis of the 

strangeness value of a classification set containing the second most likely 
allocated potential classification of the at least one unclassified example. 

2. Data classification apparatus as claimed in claim 1 , wherein the 
30 processor further includes an example valuation device which determines 

individual strangeness values for each training classified example and the 
at least one unclassified example having an allocated potential 
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classification. 

3. Data classification apparatus as claimed in claim 2, wherein 
Lagrange multipliers are used to determine the individual strangeness 

5 values. 

4. Data classification apparatus as claimed in claim 2, wherein the 
assay means determines a strangeness value for each classification set in 
dependence on the individual strangeness values of each example. 

10 

5. Data classification apparatus comprising: 

an input device for receiving a plurality of training classified 
examples and at least one unclassified example; 

a memory for storing the classified and unclassified examples; 
15 stored programs including an example classification program; 

an output terminal for outputting a predicted classification for the at least 
one unclassified example; and 

a processor controlled by the stored programs for identifying the 
predicted classification of the at least one unclassified example 
20 wherein the processor includes: 

classification allocation means for allocating potential 
classifications to each unclassified example and for generating a plurality of 
classification sets, each classification set containing the plurality of training 
classified examples and the at least one unclassified example with its 
25 allocated potential classification; 

assay means for determining a strangeness value for each 
classification set; 

a comparative device for selecting a classification set containing 
the most likely allocated potential classification for the at least one 
30 unclassified example, wherein the predicted classification output by the 

output terminal is the most likely allocated potential classification according 
to the strangeness values assigned by the assay means and 
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a strength of prediction monitoring device for determining a 
confidence value for the predicted classification on the basis of the 
strangeness value of the classification set containing the second most likely 
allocated potential classification of the at least one unclassified example. 

5 

6. A data classification method comprising: 

inputting a plurality of training classified examples and at least one 
unclassified example; 

identifying a predicted classification of the at least one unclassified 
10 example which includes, 

allocating potential classifications to each unclassified 

example; 

generating a plurality of classification sets, each classification 
set containing the plurality of training classified examples and the at least 
15 one unclassified example with its allocated potential classification; 

determining a strangeness value for each classification set; 
selecting a classification set containing the most likely 
allocated potential classification for the at least one unclassified example 
wherein the predicted classification is the most likely allocated potential 
20 classification in dependence on the strangeness values; 

determining a confidence value for the predicted classification on 
the basis of the strangeness value of the classification set containing the 
second most likely allocated potential classification for the at least one 
unclassified example; and 
25 outputting the predicted classification for the at least one 

unclassified example and the confidence value for the predicted 
classification. 

7. A data classification method as claimed in claim 6, further including 
30 determining individual strangeness values for each training classified 

example and the at least one unclassified example having an allocated 
potential classification. 
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8. A data classification method as claimed in any one of the preceding 
claims, wherein the selected classification set is selected without the 
application of any general rules determined from the training set. 

9. A data carrier on which is stored a classification program for 
classifying data by performing the following steps: 

generating a plurality of classification sets, each classification set 
containing a plurality of training classified examples and at least one 
unclassified example that has been allocated a potential classification; 

determining a strangeness value for each classification set; 

selecting a classification set containing the most likely allocated 
potential classification for the at least one unclassified example wherein the 
predicted classification is the most likely allocated potential classification in 
dependence on the strangeness values; and 

determining a confidence value for the predicted classification on the 
basis of the strangeness value of the classification set containing the 
second most likely allocated potential classification for the at least one 
unclassified example. 
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DATA CLASSIFICATION APPARATUS AND METHOD THEREOF 
BACKGROUND OF THE INVENTION 

The present invention relates to data classification apparatus and an 
automated method of data classification thereof that provides a universal 
measure of confidence in the predicted classification for any unknown 
input. Especially, but not exclusively, the present invention is suitable for 
pattern recognition, e.g. optical character recognition. 

In order to automate data classification such as pattern recognition 
the apparatus, usually in the form of a computer, must be capable of 
learning from known examples and extrapolating to predict a classification 
for new unknown examples. Various techniques have been developed 
over the years to enable computers to perform this function including, inter 
alia, discriminant analysis, neural networks, genetic algorithms and support 
vector machines. These techniques usually originate in two fields: machine 

learning and statistics. 

Learning machines developed in the theory of machine learning 
often perform very well in a wide range of applications without requiring any 
parametric statistical assumptions about the source of data (unlike 
traditional statistical techniques); the only assumption made is the iid 
assumption (the examples are generated from the same probability 
distribution independently of each other). A new approach to machine 
learning is described in US5640492, where mathematical optimisation 
techniques are used for classifying new examples. The advantage of the 
learning machine described in US5640492 is that it can be used for solving 
extremely high-dimensional problems which are infeasible for the 
previously known learning machines. 

A typical drawback of such techniques is that the techniques do not 
provide any measure of confidence in the predicted classification output by 
the apparatus. A typical user of such data classification apparatus just 
hopes that the accuracy of the results from previous analyses using 
benchmark datasets is representative of the results to be obtained from the 
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analysis of future datasets. 

Other options for the user who wants to associate a measure of 
confidence with new unclassified examples include performing experiments 
on a validation set, using one of the known cross-validation procedures, 
5 and applying one of the theoretical results about the future performance of 
different learning machines given their past performance. None of these 
confidence estimation procedures though provides any practicable means 
for assessing the confidence of the predicted classification for an individual 
new example. Known confidence estimation procedures that address the 
1 0 problem of assessing the confidence of a predicted classification for an 
individual new example are ad hoc and do not admit interpretation in 
rigorous terms of mathematical probability theory. 

Confidence estimation is a well-studied area of both parametric and 
non-parametric statistics. In some parts of statistics the goal is 
1 5 classification of future examples rather than of parameters of the model, 
which is relevant to the need addressed by this invention. In statistics, 
however, only confidence estimation procedures suitable for low- 
dimensional problems have been developed. Hence, to date 
mathematically rigorous confidence assessment has not been employed in 
20 high-dimensional data classification. 

SUMMARY OF THE INVENTION 
The present invention provides a new data classification apparatus 
and method that can cope with high-dimensional classification problems 
and that provides a universal measure of confidence, valid under the iid 
25 assumption, for each individual classification prediction made by the new 
data classification apparatus and method. 

The present invention provides data classification apparatus 
comprising: an input device for receiving a plurality of training classified 
examples and at least one unclassified example; a memory for storing the 
30 classified and unclassified examples; an output terminal for outputting a 
predicted classification for the at least one unclassified example; and a 
processor for identifying the predicted classification of the at least one 
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unclassified example wherein the processor includes: classification 
allocation means for allocating potential classifications to each unclassified 
example and for generating a plurality of classification sets, each 
classification set containing the plurality of training classified examples and 
5 the at least one unclassified example with its allocated potential 

classification; assay means for determining a strangeness value for each 
classification set; and a comparative device for selecting a classification set 
containing the most likely allocated potential classification for at least one 
unclassified example, whereby the predicted classification output by the 
1 0 output terminal is the most likely allocated potential classification, according 
to the strangeness values assigned by the assay means. 

In the preferred embodiment the processor further includes a 
strength of prediction monitoring device for determining a confidence value 
for the predicted classification on the basis of the strangeness value of a 
15 set containing the at least one unclassified example with the second most 
likely allocated potential classification. 

With the present invention the conventional data classification 
technique of induction learning and then deduction for new unknown data 
vectors is supplanted by a new transduction technique that avoids the need 
20 to identify any all encompassing general rule. Thus, with the present 
invention no multidimensional hyperplane or boundary is identified. The 
training data vectors are used directly to provide a predicted classification 
for unknown data vectors. In other words, the training data vectors 
implicitly drive classification prediction for an unknown data vector. 
25 It is important to note that with the present invention the measure of 

confidence is valid under the general iid assumption and the present 
invention is able to provide measures of confidence for even very high 
dimensional problems. 

Furthermore, with the present invention more than one unknown 
30 data vector can be classified and a measure of confidence generated 
simultaneously. 

In a further aspect the present invention provides data classification 
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apparatus comprising: an input device for receiving a plurality of training 
classified examples and at least one unclassified example; a memory for 
storing the classified and unclassified examples; stored programs including 
an example classification program; an output terminal for outputting a 
predicted classification for the at least one unclassified example; and a 
processor controlled by the stored programs for identifying the predicted 
classification of the at least one unclassified example wherein the 
processor includes: classification allocation means for allocating potential 
classifications to each unclassified example and for generating a plurality of 
classification sets, each classification set containing the plurality of training 
classified examples and the at least one unclassified example with its 
allocated potential classification; assay means for determining a 
strangeness value for each classification set; and a comparative device for 
selecting a classification set containing the most likely allocated potential 
classification for the at least one unclassified example, whereby the 
predicted classification output by the output terminal is the most likely 
allocated potential classification, according to the strangeness values 
assigned by the assay means. 

In a third aspect the present invention provides a data classification 

method comprising: 

inputting a plurality of training classified examples and at least one 

unclassified example; 

identifying a predicted classification of the at least one unclassified 

example which includes 

allocating potential classifications to each unclassified 

example; 

generating a plurality of classification sets each containing the 
plurality of training classified examples and the at least one unclassified 
example with an allocated potential classification; 

determining a strangeness value for each classification set; 

and 

selecting, according to the assigned strangeness values, a 
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classification set containing the most likely allocated potential classification; 
and outputting the predicted classification for the at least one unclassified 
example whereby the predicted classification output by an output terminal 
is the most likely allocated potential classification. 

It will, of course, be appreciated that the above method and 
apparatus may be implemented in a data carrier on which is stored a 

classification program. 

BRIEF DESCRIPTION OF THE DRAWINGS 

An embodiment of the present invention will now be described by 
way of example only with reference to the accompanying drawings, in 
which: 

Figure 1 is a schematic diagram of data classification apparatus in 
accordance with the present invention; 

Figure 2 is a schematic diagram of the operation of data 
classification apparatus of Figure 1 ; 

Figure 3 is a table showing a set of training examples and 
unclassified examples for use with a data classifier in accordance with the 

present invention; and 

Figure 4 is a tabulation of experimental results where a data 
classifier in accordance with the present invention was used in character 
recognition. 

DESCRIPTION OF PREFERRED EMBODIMENT 

In Figure 1 a data classif ier 10 is shown generally consisting of an 
input device 1 1 , a processor 1 2, a memory 1 3, a ROM 1 4 containing a 
suite of programs accessible by the processor 1 2 and an output terminal 
15. The input device 11 preferably includes a user interface 16 such as a 
keyboard or other conventional means for communicating with and 
inputting data to the processor 12 and the output terminal 15 may be in the 
form of a display monitor or other conventional means for displaying 
■information to a user. The output terminal 15 preferably includes one or 
more output ports for connection to a printer or other network device. The 
data classifier 10 may be embodied in an Application Specific Integrated 
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Circuit (ASIC) with additional RAM chips. Ideally, the ASIC would contain a 
fast RISC CPU with an appropriate Floating Point Unit. 

To assist in an understanding of the operation of the data classifier 
10 in providing a prediction of a classification for unclassified (unknown) 
5 examples, the following is an explanation of the mathematical theory 
underlying its operation. 

Two sets of examples (data vectors) are given: the training set 
consists of examples with their classifications (or classes) known and a test 
set consisting of unclassified examples. In Figure 3, a training set of five 
1 0 examples and two test examples are shown, where the unclassified 
examples are images of digits and the classification is either 1 or 7. 

The notation for the size of the training set is / and, for simplicity, it is 
assumed that the test set of examples contains only one unclassified 
example. Let (X,A) be the measurable space of all possible unclassified 
1 5 examples (in the case of Figure 3, X might be the set of all 1 6 x 1 6 grey- 
scale images) and (Y,B) be the measurable space of classes (in the case 
of Figure 3, Y might be the 2-element set {1 , 7}). Y is typically finite. 

The confidence prediction procedure is a family {/ p :pe(0, 1]} of 
measurable mappings / P :(X x Y)' x X->B such that: 
20 1. For any confidence level )3 (in data classification typically we are 

interested in p close to 1) and any probability distribution Pin X x Y, the 
probability that 

y l+ , e / fl (x,,yi.~.*/.y/.*/ + i) 

25 is at least j3, where (*,,>,)...., (*,,:y,M*, + i.;y, + .) are generated independently 
from P. 

2. If 01 < #>, then, for all (x xt y x ,... t x,,y,,x M )e(X xYfxX, 

30 / A (x |t . v, ,-.*/. y/. *m) c / ft u, .yi.-* x /»yi.jfi + i) 
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The assertion implicit in the prediction f p> U,, y... y,,*, + i) is that the true 

label y, +1 will belong to / A (x„y, ?,.*,♦.)• Item 1 requires that the 

prediction given by fa should be correct with probability at least p, and item 
2 requires that the family {fp} should be consistent: if some label y for the 
5 (/+1 )th example is allowed at confidence level j8i , it should also be allowed 

at any confidence level fiz > 0i- 

A typical mode of use of this definition is that some conventional 
value of p such as 95% or 99%. is chosen in advance, after which the 
function j> is used for prediction. Ideally, the prediction region output by f fi 

10 will contain only one classification. 

An important feature of the data classification apparatus is defining 
fp in terms of solutions ow, *=1 , .... A-1 , to auxiliary optimisation problems of 
the kind outlined in US5640492, the contents of which is incorporated 
herein by reference. Specifically, we consider I Yl completions of our data 

15 (.x,,y,).—.(*i. 
the completion y, ye Y, is 

(Jt,,y,) (x,,y, \{x l+l ,y) 

(so in all completions every example is classified). 
With every completion 
20 (*n y>\ )>-> ( x /»y»)»( x /+i *>'/+i ) 

(for notational convenience we write y M in place of y here) is associated 
the optimisation problem 

I(w»0 + C^^j »min 0) 

(where C is a fixed positive constant) 
25 subject to the constraints 

y.((x,.w) + Z>)>^,/ = l.-,/ + l (2) 

This problem involves non-negative variables 0, which are called slack 
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variables. If the constant Cis chosen too large, the accuracy of solution 
can become unacceptably poor; C should be chosen as large as possible 
in the range in which the numerical accuracy of solution remains 
reasonable. (When the data is linearly separable, it is even possible to set 
5 C to infinity, but since it is rarely if ever possible to tell in advance that all 
completions will be linearly separable, C should be taken large but finite.) 

The optimisation problem is transformed, via the introduction of 
Lagrange multipliers a* M , A-1 . to the dual problem: find a, from 

i=l 2 i.j=l 

1 0 under the "box" constraints 

0 < at < C, fe1 , 2, .... A-1 (4) 
The unclassified examples are represented, it is assumed, as the values 
taken by n numerical attributes and so X= FT. 

This quadratic optimisation problem is applied not to the attribute 
1 5 vectors x, themselves, but to their images V(x/) under some predetermined 
function V:X-> H taking values in a Hilbert space, which leads to replacing 
the dot product x, -xj in the optimisation problem (3)— (4) by the kernel 
function 

K(x,,Xj)=V(xb • V(Xj) 
20 The final optimisation problem is, therefore, 

X a > ■- t X y «y i a ' a J K v> • x p ~* max 

under the "box" constraints 

0 < a, < C, a=1 , 2 A-1 

this quadratic optimisation problem can be solved using standard 
25 packages. 

The Lagrange multiplier a/, /e{1 A-1}, reflects the "strangeness" 

of the example (x/,y>); we expect that cxm will be large in the wrong 

completions. 

For ye Y, define 
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1 {/:«,-><*,„) | 
d(y) := ^ 

therefore d(y) is the p-value associated with the completion y (y being an 
alternative notation for y M )- The confidence prediction function /, which is 
at the core of this invention, can be expressed as 

5 f p (*, , y, x, , y, , x M ) := {y : d(y) > 1 - p} 

The most interesting case is where the prediction set given by / p is a 
singleton; therefore, the most important features of the confidence 
prediction procedure {/p} at the data (x,, y, ),..., (x,,y,),x M are: 
• the largest p=(3 0 for which f p ((.x t ,y i ),...,(x l ,y l ),x l+i ) is a singleton 

10 (assuming such a p* exists); 

. the classification F ((*,,?,),.-., (*,.>'/W.) defined to be that ye Yfor 
which fp tt «x it >'„..., (*,,?,)»*/+.) is{y}. 

FC^.y,),...^^^,),^,) defined in this way is called the /-optimal 
1 5 prediction algorithm; the corresponding p 0 is called the confidence level 

associated with F. 

Another important feature of the confidence estimation function {/p} 
at the data (x„y, ),..., (x„y,),x l+i is the largest p=p\ for which 
/ 1 i((x 1 .y,)....(x ( ,y l ).x w ) is the empty set. Wecall 1 -p. the credibility of the 

20 data set {x l .y l ).....{x n y,).x M ; it is the p-value of a test for checking the iid 
assumption. Where the credibility is very small, either the training set 
(x„y { ),..., (x,,y,) or the new unclassified example x M are untypical, which 
renders the prediction unreliable unless the confidence level is much closer 
to 1, than is 1-p\. In general, the sum of the confidence and credibility is 

25 between 1 and 2; the success of the prediction is measured by how close 

this sum is to 2. 

With the data classifier of the present invention operated as 
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described above, the following menus or choices may be offered to a user: 

1 . Prediction and Confidence 

2. Credibility 

3. Details. 

5 A typical response to the user's selection of choice 1 might be 

prediction: 4, confidence: 99%, which means that 4 will be the prediction 
output by the /-optimal F and 99% is the confidence level of this prediction. 
A typical response to choice 2 might be credibility: 100%, which gives the 
computed value of credibility. A typical response to choice 3 might be: 

012 3 4 5 6789 

0.1% 1% 0.2% 0.4% 100% 1.1% 0.6% 0.2% 1% 1% 
10 the complete set of p-values for all possible completions. The latter choice 

contains the information about F((jr,,y,) (*,,y/ W.) ( the character 

corresponding to the largest p-value), the confidence level (one minus the 
second largest p-value) and the credibility (the largest p-value). 

This mode of using the confidence prediction function / is not the 
1 5 only possible mode: in principle it can be combined with any prediction 
algorithm. If G is a prediction algorithm, with its prediction 
y.=G ((*,,. y, ),...,(*„ y,),;r ;+ j we can associate the following measure of 
confidence: 

c(y) := max-(/3 : f p (*, , y x, , y, , x M ) c {y}} 

20 The prediction algorithm F described above is the one that optimises this 
measure of confidence. 

The table shown in Figure 4 contains the results of an experiment in 
character recognition using the data classifier of the present invention. The 
table shows the results for a test set of size 1 0, using a training set of size 
25 20 (not shown). The kernel used was K(x,y) = (x- y) y /256 . 

It is contemplated that some modifications of the optimisation 
problem set out under equations (I) and (2) might have certain advantages, 
for example, 



WO 00/28473 



PCT/GB99/03737 



11 



1 \ i=i 



— » min. 



J 



subject to the constraints 

>••,((*, • w) + b) = 1 - 1 ' + 1 

It is further contemplated that the data classifier described above 
may be particularly useful for predicting the classification of more than one 
example simultaneously; the test statistic used for computing the p-values 
corresponding to different completions might be the sum of the ranks of as 
corresponding to the new examples (as in the Wilcoxon rank-sum test). 

In practice, as shown in Figure 2, a training dataset is input 20 to the 
data classifier. The training dataset consists of a plurality of data vectors 
each of which has an associated known classification allocated from a set 
of classifications. For example, in numerical character recognition, the set 
of classifications might be the numerical series 0—9. The set of 
classifications may separately be input 21 to the data classifier or may be 
stored in- the ROM 14. In addition, some constructive representation of the 
measurable space of the data vectors may be input 22 to the data classifier 
or again may be stored in the ROM 14. For example, in the case of 
numerical character recognition the measurable space might consist of 
16x16 pixellated grey-scale images. Where the measurable space is 
already stored in the ROM 14 of the data classifier, the interface 16 may 
include input means (not shown) to enable a user to input adjustments for 
the stored measurable space. For example, greater-definition of an image 
may be required in which case the pixellation of the measurable space 

could be increased. 

One or more data vectors for which no classification is known are 
also input 23 into the data classifier. The training dataset and the 
unclassified data vectors along with any additional information input by the 
user are then fed from the input device 1 1 to the processor 12. 

Firstly, each one of the one or more unclassified data vectors is 
provisionally individually allocated 24 a classification from the set of 
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classifications. An individual strangeness value a,- is then determined 25 
for each of the data vectors in the training set and for each of the 
unclassified data vectors for which a provisional classification allocation 
has been made. A classification set is thus generated containing each of 
5 the data vectors in the training set and the one or more unclassified data 
vectors with their allocated provision classifications and the individual 
strangeness values oc/for each data vector. A plurality of such classification 
sets is then generated with the allocated provisional classifications of the 
unclassified data vectors being different for each classification set. 
10 Computation of a single strangeness value, the p-value, for each 

classification set containing the complete set of training data vectors and 
unclassified vectors with their current allocated classification is then 
performed 26, on the basis of the individual strangeness values a> 
determined in the previous step. This p-value and the associated set of 
1 5 classifications is transferred to the memory 1 3 for future comparison whilst 
each of the one or more unclassified data vectors is provisionally 
individually allocated with the same or a different classification. The steps 
of calculating individual strangeness values 25 and the determination of a 
p-value 26 are repeated in each iteration for the complete set of training 
20 data vectors and the unclassified data vectors, using different classification 
allocations for the unclassified data vectors each time. This results in a 
series of p-values being stored in the memory 13 each representing the 
strangeness of the complete set of data vectors with respect to unique 
classification allocations for the one or more unclassified data vectors. 
25 The p-values stored in the memory are then compared 27 to identify 

the maximum p-value and the next largest p-value. Finally, the 
classification set of data vectors having the maximum p-value is supplied 
28 to the output terminal 1 5. The data supplied to the output terminal may 
consist solely of the classification (s) allocated to the unclassified data 
30 vector(s), which now represents the predicted classification, from the 
classification set of data vectors having the maximum p-value. 

Furthermore, a confidence value for the predicted classification is 
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generated 29. The confidence value is determined based on the 
subtraction of the next largest p-value from 1 . Hence, if the next largest p- 
value is large, the confidence of the predicted classification is small and if 
the next largest p-value is small, the confidence value is large. Choice 1 
5 referred to earlier, provides a user with predicted classifications for the one 
or more unknown data vectors and the confidence value. 

Where an alternative prediction algorithm is to be used, the 
confidence value will be computed by subtracting from 1 the largest p-value 
for the sets of training data vectors and new vectors classified differently 
1 0 from the predicted (by the alternative method) classification. 

Additional information in the form of the p-values for each of the sets 
of data vectors with respect to the individual allocated classifications may 
also be supplied (choice 3) or simply the p-value for the predicted 
classification (choice 2). 
1 5 With the data classifier and method of data classification described 

above, a universal measure of the confidence in any predicted 
classification of one or more unknown data vectors is provided. Moreover, 
at no point is a general rule or multidimensional hyperplane extracted from 
the training set of data vectors. Instead, the data vectors are used directly 
20 to calculate the strangeness of a provisionally allocated classification(s) for 
one or more unknown data vectors. 

While the data classification apparatus and method have been 
particularly shown and described with reference to the above preferred 
embodiment, it will be understood by those skilled in the art that various 
25 modifications in form and detail may be made therein without departing 
from the scope and spirit of the invention. Accordingly, modifications such 
as those suggested above, but not limited thereto, are to be considered 
within the scope of the invention. 



30 



WO 00/28473 




PCT/GB99/03737 



CLAIMS 



1 . Data classification apparatus comprising: 

an input device for receiving a plurality of training classified 
5 examples and at least one unclassified example; 

a memory for storing the classified and unclassified examples; 

an output terminal for outputting a predicted classification for the at 
least one unclassified example; and 

a processor for identifying the predicted classification of the at least 
1 0 one unclassified example 

wherein the processor includes: 

classification allocation means for allocating potential classifications 
to each unclassified example and for generating a plurality of classification 
sets, each classification set containing the plurality of training classified 
15 examples and the at least one unclassified example with its allocated 
potential classification; 

assay means for determining a strangeness value for each 

classification set; 

a comparative device for selecting a classification set containing the 
20 most likely allocated potential classification for the at least one unclassified 
example, wherein the predicted classification output by the output terminal 
is the most likely allocated potential classification according to the 
strangeness values assigned by the assay means; and 

a strength of prediction monitoring device for determining a 
25 confidence value for the predicted classification on the basis of the 

strangeness value of a classification set containing the second most likely 
allocated potential classification of the at least one unclassified example. 

2. Data classification apparatus as claimed in claim 1 , wherein the 
30 processor further includes an example valuation device which determines 
individual strangeness values for each training classified example and the 
at least one unclassified example having an allocated potential 
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classification. 

3. Data classification apparatus as claimed in claim 2, wherein 
Lagrange multipliers are used to determine the individual strangeness 

5 values. 

4. Data classification apparatus as claimed in claim 2, wherein the 
assay means determines a strangeness value for each classification set in 
dependence on the individual strangeness values of each example. 

10 

5. Data classification apparatus comprising: 

an input device for receiving a plurality of training classified 
examples and at least one unclassified example; 

a memory for storing the classified and unclassified examples; 
1 5 stored programs including an example classification program; 

an output terminal for outputting a predicted classification for the at least 
one unclassified example; and 

a processor controlled by the stored programs for identifying the 
predicted classification of the at least one unclassified example 
20 wherein the processor includes: 

classification allocation means for allocating potential 
classifications to each unclassified example and for generating a plurality of 
classification sets, each classification set containing the plurality of training 
classified examples and the at least one unclassified example with its 
25 allocated potential classification; 

assay means for determining a strangeness value for each 

classification set; 

a comparative device for selecting a classification set containing 
the most likely allocated potential classification for the at least one 
30 unclassified example, wherein the predicted classification output by the 

output terminal is the most likely allocated potential classification according 
to the strangeness values assigned by the assay means and 
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a strength of prediction monitoring device for determining a 
confidence value for the predicted classification on the basis of the 
strangeness value of the classification set containing the second most likely 
allocated potential classification of the at least one unclassified example. 

6. A data classification method comprising: 

inputting a plurality of training classified examples and at least one 

unclassified example; 

identifying a predicted classification of the at least one unclassified 

example which includes, 

allocating potential classifications to each unclassified 

example; 

generating a plurality of classification sets, each classification 
set containing the plurality of training classified examples and the at least 
one unclassified example with its allocated potential classification; 

determining a strangeness value for each classification set; 

selecting a classification set containing the most likely 
allocated potential classification for the at least one unclassified example 
wherein the predicted classification is the most likely allocated potential 
classification in dependence on the strangeness values; 

determining a confidence value for the predicted classification on 
the basis of the strangeness value of the classification set containing the 
second most likely allocated potential classification for the at least one 

unclassified example; and 

outputting the predicted classification for the at least one 
unclassified example and the confidence value for the predicted 
classification. 

7. A data classification method as claimed in claim 6, further including 
determining individual strangeness values for each training classified 
example and the at least one unclassified example having an allocated 
potential classification. 
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8. A data classification method as claimed in any one of the preceding 
claims, wherein the selected classification set is selected without the 
application of any general rules determined from the training set. 

5 

9. A data carrier on which is stored a classification program for 
classifying data by performing the following steps: 

generating a plurality of classification sets, each classification set 
containing a plurality of training classified examples and at least one 
1 0 unclassified example that has been allocated a potential classification; 

determining a strangeness value for each classification set; 

selecting a classification set containing the most likely allocated 
potential classification for the at least one unclassified example wherein the 
predicted classification is the most likely allocated potential classification in 
1 5 dependence on the strangeness values; and 

determining a confidence value for the predicted classification on the 
basis of the strangeness value of the classification set containing the 
second most likely allocated potential classification for the at least one 
unclassified example. 
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